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Foreword 

This Technical Specification has been produced by the 3"* Generation Partnership Project (3GPP). 

The contents of the present document are subject to continuing work within the TSG and may change following formal 
TSG approval. Should the TSG modify the contents of the present document, it will be re-released by the TSG with an 
identifying change of release date and an increase in version number as follows: 

Version x.y.z 

where: 

X the first digit: 

1 presented to TSG for information; 

2 presented to TSG for approval; 

3 or greater indicates TSG approved document under change control. 

y the second digit is incremented for all changes of substance, i.e. technical enhancements, corrections, 
updates, etc. 

z the third digit is incremented when editorial only changes have been incorporated in the document. 
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1 Scope 

The present document is part of a series of documents that specify charging functionality and charging management in 
GSM/UMTS networks. The GSM/UMTS core network charging architecture and principles are specified in 3GPP 
TS 32.240 [1], which provides an umbrella for other charging management TSs that specify: 

- the content of the CDRs per domain / subsystem / service (offline charging), 

- the content of real-time charging messages per domain / subsystem / service (online charging); 

- the fimctionaUty of online and offline charging for those domains / subsystems / services; 

- the interfaces that are used in the charging framework to transfer the charging information (i.e. CDRs or charging 
events) 

The complete document structure for these TSs is defined in TS 32.240 [1]. 

The present document specifies the transaction based mechanism for the near real time transfer of CDRs 
within the network. 

The present document is related to other 3GPP charging TSs as follows: 

■ The common 3GPP charging architecture is specified in TS 32.240 [1]; 

■ The parameters, abstract syntax and encoding rules for the CDRs are specified in TS 32.298 [51]; 

■ The file based mechanism used to transfer the CDRs from the network to the operator's billing domain (e.g. the 
post-processing system or a mediation device) is specified in TS 32.297 [52]; 

The 3GPP Diameter application that is used for offline and online charging is specified in TS 32.299 [50]. 

All terms, definitions and abbreviations used in the present document, that are common across 3GPP TSs, are defined in 
the 3GPP Vocabulary, TR 21.905 [100]. Those that are common across charging management in GSM/UMTS domains 
services, or subsystems are provided in the umbrella document TS 32.240 [1] and are copied into clause 3 of the present 
document for ease of reading. Finally, those items that are specific to the present document are defined exclusively in 
the present document. 

Furthermore, requirements that govern the charging work are specified in 3 GPP TS 22.115 [102]. 



2 References 

The following documents contain provisions which, through reference in this text, constitute provisions of the present 
document. 

• References are either specific (identified by date of publication, edition number, version number, etc.) or 
non-specific. 

• For a specific reference, subsequent revisions do not apply. 

• For a non-specific reference, the latest version applies. In the case of a reference to a 3GPP document (including 
a GSM document), a non-specific reference implicitly refers to the latest version of that document in the same 
Release as the present document. 

[I] 3GPP TS 32.240: "Telecommunication management; Charging management; Charging 
Architecture and Principles". 

[2]-[9] Void. 

[10] 3GPP TS 32.250: "Teleconmiunication management; Charging management; Circuit Switched 

(CS) domain charging". 

[II] -[29] Void. 
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[30] 3GPP TS 32.270: "Telecommunication management; Charging management; Multimedia 

Messaging Service (MMS) charging". 

[31]-[49] Void. 

[50] 3GPP TS 32.299: "Telecommunication management; Charging management; Diameter charging 

application". 

[51] 3GPP TS 32.298: "Telecommunication management; Charging management; Charging Data 

Record (CDR) parameter description". 

[52] 3GPP TS 32.297: "Telecommunication management; Charging management; Charging Data 

Record (CDR) file format and transfer". 

[53]-[99] Void. 

[100] TR 21.905: "Vocabulary for 3GPP Specifications". 

[1011-L199J Void. 

[200] 3GPP TS 29.060: "General Packet Radio Service (GPRS); GPRS Tunnelling Protocol (GTP) 

across the Gn and Gp interface". 

[201]-[299] Void. 

[300]-[399] Void. 

[400-403] Void. 

[404] IETF RFC 768 (1980): "User Datagram Protocol" (STD 6). 

[405] IETF RFC 793 (1981): "Transmission Control Protocol" (STD 7). 

[406] IETF RFC 791 (1981): "Internet Protocol" (STD 5). 

[407] IETF RFC 792 (1981): "Internet Control Message Protocol" (STD 5). 



3 Definitions, symbols and abbreviations 
3.1 Definitions 

For the purposes of the present document, the following terms and definitions given in 3GPP TR 21.905 [50], 3GPP 
TS 32.240 [1], and the following apply: 

2G- / 3G-: prefixes 2G- and 3G- refers to functionahty that supports only GSM or UMTS, respectively, e.g. 2G-CDF 
refers only to the GSM fimctionality of an CDF. 

accounting: process of apportioning charges between the Home Environment, Serving Network and User. 

billing: function whereby CDRs generated by the charging function are transformed into bills requiring payment. 

Billing Domain: Part of the operator network, which is outside the core network, that receives and processes CDR files 
from the core network charging functions. It includes functions that can provide billing mediation and bilUng other (e.g. 
statistical) end applications. It is only applicable to offline charging (see "Online Charging System" for equivalent 

functionality in online charging). 

CDR field Categories: the CDR fields are defined in the present document. They are divided into the following 

categories: 

• Mandatory (M): field that shall be present in the CDR. 

• Conditional (C): field that shall be present in a CDR if certain conditions are met. 
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• Operator Provisionable: Mandatory (Om): A field that operators have provisioned to be included in the CDR 
for all conditions. 

• Operator Provisionable: Conditional (Oc): A field that operators have provisioned to be included in the CDR 
if certain conditions are met. 

chargeable event: activity utilizing telecommunications network infrastructure and related services for: 

■ user to user communication (e.g. a single call, a data communication session or a short message); or 

■ user to network communication (e.g. service profile administration); or 

■ inter-network communication (e.g. transferring calls, signalling, or short messages); or 

■ mobility (e.g. roaming or inter-system handover); and 

■ that the network operator wants to charge for. 

charged party: user involved in a chargeable event who has to pay parts or the whole charges of the chargeable event, 
or a third party paying the charges caused by one or all users involved in the chargeable event, or a network operator. 

charging: function whereby information related to a chargeable event is formatted and transferred in order to make it 
possible to determine usage for which the charged party may be billed. 

Charging Data Record (CDR): A formatted collection of information about a chargeable event (e.g. time of call set- 
up, duration of the call, amount of data transferred, etc) for use in billing and accounting. For each party to be charged 
for parts of or all charges of a chargeable event a separate CDR shall be generated, i.e. more than one CDR may be 
generated for a single chargeable event, e.g. because of its long duration, or because more than one charged party is to 
be charged. 

charging function: entity inside the core network domain, subsystem or service that is involved in charging for that 
domain, subsystem or service. 

circuit switched domain: domain within GSM / UMTS in which information is transferred in circuit mode, 
domain: part of a communication network that provides services using a certain technology. 

GPRS: Packet Services for GSM and UMTS systems. 

GTP': GPRS protocol, used for CDR transport. It is derived from GTP with enhancements to improve transport 
reliability necessary for CDRs. NOTE:This protocol is not used for tunnelling. 

GSM only: qualifier indicating that this clause or paragraph applies only to a GSM system. For multi-system cases this 
is determined by the current serving radio access network. 

inter-system change: change of radio access between different radio access technologies such as GSM and UMTS, 
in GSM,...: qualifier indicating that this paragraph applies only to GSM System, 
in UMTS,...: qualifier indicating that this paragraph applies only to UMTS System. 

middle tier (charging) TS: used for the 3GPP charging TSs that specify the domain / subsystem / service specific, 
online and offline, charging functionality. These are all the TSs in the numbering range from 3GPP TS 32.250 [10] to 
3GPP TS 32.27X [3x], e.g. 3GPP TS 32.250 [10] for the CS domain, or 3GPP TS 32.270 [30] for the MMS service. 
Currently, there is only one "tier 1" TS in 3GPP, which is the TS 32.240 [1] that specifies the charging architecture and 
principles. Finally, there are a number of top tier TSs in the 32.29x numbering range ([50] ff) that specify common 
charging aspects such as parameter definitions, encoding rules, the common BD interface or common charging 
applications. 

near real time: near real time charging and billing information is to be generated, processed, and transported to a 
desired conclusion in less than 1 minute. 

observed IMEI ticket: record used to describe an EIR relevant event e.g. a blacklisted IMEI. 

offline charging: charging mechanism where charging information does not affect, in real-time, the service rendered. 
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online charging: charging mechanism where charging information can affect, in real-time, the service rendered and 
therefore a direct interaction of the charging mechanism with session/service control is required. 

Online Charging System: ffs. 

packet switched domain: domain within GSM and UMTS in which data is transferred in packet switched mode. 
Corresponds to the term "GPRS". 

Real-time: real time charging and billing information is to be generated, processed, and transported to a desired 
conclusion in less than 1 second. 

subscriber: A subscriber is an entity (associated with one or more users) that is engaged in a Subscription with a 

service provider. The subscriber is allowed to subscribe and unsubscribe services, to register a user or a list of users 
authorised to enjoy these services, and also to set the Umits relative to the use that associated users make of these 
services. 

UMTS only: qualifier indicating that this clause or paragraph applies only to a UMTS system. For multi-system cases 
this is determined by the current serving radio access network. 

user: An entity, not part of the 3GPP System, that uses network resources by means of a subscription. The user may or 
may not be identical to the subscriber holding that subscription. 



For the purposes of the present document, the abbreviations defined in 3GPP TR 21.905 [50], 3GPP TS 32.240 [1] and 
the following apply: 



3.2 



Abbreviations 



GTP 
GTP' 
IE 
IP 

IPv4 

IPv6 

NE 

DCS 

PDN 

PS 

PT 



3G 

3GPP 

AS 

ASN.l 



BD 

CDF 

CDR 

CG 

CGF 

CS 



TAP 
TLV 
TV 



GPRS 



S-SMO-CDR 



3™ Generation 

3"^ Generation Partnership Project 

Application Server 

Abstract Syntax Notation One 

Billing Domain 

Charging Data Function 

Charging Data Record 

Charging Gateway 

Charging Gateway Function 

Circuit SwitchedDRP Data Record Packet 

General Packet Radio Service 

GPRS Tunnelling Protocol 

GPRS protocol, used for CDR transport 

Information Element 

Internet Protocol 

Internet Protocol version 4 

Internet Protocol version 6 

Network Element 

Online Charging System 

Packet Data Network 

Packet-Switched 

Protocol Type (Field in GTP' header) 

SGSN Short Message Mobile Originated - CDR 

Transferred Account Procedure 

Type, Length, Value (GTP header format) 

Type, Value 



3.3 



Symbols 



For the purposes of the present document, the following symbols apply: 



Bx 
Ga 
Rf 



The reference point between any (generic) 3G domain, subsystem or service CGF and the BD. 
Reference point between a CDF and the CGF for CDR transfer. 

Reference Point between the CTF within a 3G network element and the CDF for offline charging. 
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4 Architecture Considerations 
4.1 High level architecture 

The Ga is the reference point from the Charging Data Function (CDF) to the Charging Gateway Function (CGF), which 
is intended for the transport of Charging Data Records (CDRs). 

By definition, deaUng with CDRs only impUes that Ga is solely related to offline charging. 

The following figure 4.1 depicts the position of the Ga reference point within the overall 3GPP offline charging 
architecture. 



3GPP network 




Billing 
Domain 



CTF: Charging Trigger Function 
CDF: Charging Data Function 
CGF: Charging Gateway Function 

BD: Billing Domain. This may also be a billing mediation device / post-processing system. 

Figure 4.1 : Logical ubiquitous offline charging architecture 

As illustrated in the above figure 4.1, the CDF in each network domain, service or subsystem is relevant for the network 
side of the Ga reference point. Different mappings of the ubiquitous offline charging functions, CDF and CGF, onto 
physical implementations are possible. Further details of the configuration refer to 3GPP TS 32.240 [1]. Details of the 
implementation options per domain / subsystem / service (usually a subset of the overall possible variants described 
above) are specified in the respective middle tier TS. 

The transport protocol associated to the Ga reference point, providing functions for transfer of CDRs from CDF to 
CGF, is GTP' (because of its derivation from the GTP protocol). 



5 Transfer principles and scenarios 
5.1 Transfer principles 

The GTP' protocol is optional, and is used for CDR transport between the CDFs and the CGF. 
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5.1 .1 Charging related transfer requirements 

Each CDF will have an O&M configurable address Ust of CGFs (Charging Gateways) to which it can send its CDRs. 
The list will be organized in CGF address priority order. If the primary CGF is not available (e.g. out of service), then 
the CDF shall send the CDRs to the secondary CGF and so on. 

For PDF context related CDRs in the PS domain, the address of the CGF which the CDRs have to be sent to, will be 
determined at PDP context creation (e.g. in the GTP message Create POP Context Response). 

But for non-PDP-context-related CDRs (e.g. S-SMO-CDRs), no CGF address information wiU be passed to the CDF. 

In these cases, the CDF should transmit the CDRs to a 'default CGF'. 

The 'default CGF' address should be an O&M configurable item on the CDF. 

Each CDR generating function will only send the records to the CGF(s) of the same PLMN, not to CGF(s) located in 
other PLMNs. 

Each CGF in the PLMN may know of other CGFs' network addresses (e.g., for redundancy reasons, to be able to 
recommend another CGF address). This is achieved by O&M configuration faciUties that will enable each CGF to have 
a configurable list of peer CGF addresses. 

5.1 .2 CDR Transport by GTP' 

GTP' has been designed to deliver the CDR(s) from the CDF, which generates charging data records (CDRs) to the 
CGF(s). This protocol is required if the CGF resides outside the CDFs. It utilizes some aspects of GTP (defined in TS 
29.060 [200]), which is used for packet data tunnelling in the backbone network. 

GTP' operates on the Ga interface and does not imply the use of any specific backbone network. 

GTP' performs the following functions: 

■ CDR transfer between the CDF and the CGF. 

■ Redirection of CDRs to another CGF. 

■ Detect communication failures between the communicating peers, using echo messaging. 

■ Advertise to peers about its CDR transfer capability (e.g., after a period of service downtime). 

■ Prevents duplicate CDRs that might arise during redundancy operations. 

If so configured, the CDR duplication prevention function may also be carried out by marking potentially 
duplicated CDR packets, and, delegating the final duplicate deletion task to a CGF or the BilUng Domain 
(instead of handling the possible duplicates solely by GTP' messaging). 
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5.1 .2.1 CDF - CGF communication 

As illustrated in Figure 5.1, the CDF - CGF communications are carried out using GTP' over UDP/TCP and IP. 
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UDP/TCP 
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Figure 5.1 : Protocoi iayers between tlie CDF and tlie CGF 



5.1.2.2 CGF - CGF communication 

If necessary, CGF to CGF communications are carried out using GTP' over UDP/TCP and IP. 
This is illustrated in Figure 5.2. 
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IP 
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Figure 5.2: Protocol layers between CGFs 

5.1.3 Port usage 

Transporting the CDRs from the CDFs to the CGF over the Ga reference point may facilitate charging. 

The Path Protocol may be UDP (comphant with STD 0006[404]) or TCP (compliant with STD 0007[405]) over IP. 

• UDP as the Path Protocol 
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Ports for signalling the request messages: 

The UDP Destination Port may be the server port number 3386 which has been reserved for GTP'. 
Alternatively another port can be used, which has been configured by O&M. 

The UDP Source Port is a locally allocated port number at the sending network element. 

Ports for signalling the response messages: 

The UDP Destination Port value shall be the value of the Source Port of the corresponding request 
message. 

The UDP Source Port shall be the value from the Destination Port of the corresponding request message. 

• TCP as Path Protocol 

The TCP Destination Port may be the server port number 3386, which has been reserved for G-PDUs. Alternatively, 
another port may be used as configured by O&M. Extra implementation-specific destination ports are possible but 
all CGFs shall support the server port number. 

The TCP Source Port is a random port, locally assigned at the sending network element. 

• Network layer and lower layers 

Beneath the Path Protocol there is the network IP layer, which shall be the Internet Protocol (IP) compliant with 
STD 0005(see [406] and [407]). Beneath the network IP layer are the L2 and LI layers, which are not specified, in 
the present document. 



Each function (i.e. CDF and CGF) that supports the GTP' shall be capable of handling or responding with a 

" ServiceA^ersion not supported" message if that function is configured to be addressed by another peer function. 



The following example cases represent the three different key Data Record Transfer Request/Response messaging 
related CDR handUng schemes. Cases (2) and (3) represent situations involving the redundancy mechanism. 

(1) The normal CDR packet transfer: 

The CDF sends successfully a CDR packet to the CGF, and since the CDF gets a response (Request Accepted) for 
the Data Record Transfer Request, there is no need to use the CGF redimdancy mechanism and redirect the CDR 
packet traffic flow to an other CGF. 

(2) The CDF-CGF cormection breaks before a successful CDR reception: 

In this case the CDR packet sent by the CDF is lost before it is received by the CGF. (The loss might be caused by a 
link failure or e.g. a major CGF failure.) 

(3) The CDF-CGF connection breaks after a successful CDR reception: 

In this case the CDR sent by the CDF is received correctly by the CGF and moved to its non-volatile memory 
(or even to the next NE in the communication chain). Anyhow, the CDF-CGF communication stops working, in this 
example case, before the CDF gets the positive response (Data Record Transfer Response: Request Accepted) 
which would acknowledge that the CDR packet was successfully received by CGF. 

(4) CGF redundancy mechanism 

An overview on the mechanism, involved in cases (2) and (3), preventing dupUcated CDR packets to enter a BD. 



5.2 



GTP' transfer scenarios 



5.2.1 



Basic principles 



5.2.2 GTP' messaging cases 
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The next four clauses describe in more detail each of these key Data Record Transfer Request/ Response messaging 
schemes. 



5.2.2.1 



The normal CDR packet transfer 



Figure 5.3 represents the default mode of CDR transfer from the CDR generating functions (CDFs) to the CDR 
collecting functions (CGFs). 



CDF 



4. < Succesfully 
sent CDRs are deleted 
from the CDF 
buffers > 



1 . Data Record Transfer 
Request: Send Data 
Record Packet 



3. Data Record Transfer 
Response: Request 
Accepted 



CGF's 
volatile memory 



Non-volatile 
CGF memory 



2. CDRs are stored 
in a secure way 



Figure 5.3: A normal CDR transfer process between a CDF and CGF 



1) The CDR generating entity sends CDR(s) in a packet to CGF (that is the current primary Charging Gateway 
Functionality for the specific CDF, "CGFl"). The sending is performed by using the Data Record Transfer 
Request message, with the Packet Transfer Command IE having the value "Send Data Record Packet". 

2) The CGF opens the received message and stores the packet contents in a safe way (to e.g. a redimdant RAM 
memory unit or a mirrored non- volatile memory or even to another node). 

3) The CDR receiving entity (CGF) sends confirmation of the successful packet reception to the CDF (CDF). The 
confirmation is performed by using the Data Record Transfer Response message, with the Cause value being 
"Request Accepted". 

4) After the positive response "Request Accepted" is received by the CDF, it may delete the successfully sent 
CDRs from its send buffer. 

The general principle of GTP' to retransmit the request if the response has not been received within a configurable time- 
out Umit, is also followed here in point 1). The maximum amount of retries is a configurable value. 
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5.2.2.2 



The CDF-CGF connection breaks before a successful CDR reception 



Figure 5.4 describes the exceptional case when the CDR transfer from a CDR generating entity (CDF) to the primary 
CDR packet collecting entity (CGFl) fails in a way that the CGFl is not able to store the CDR packet sent by the CDF. 
(The reason for the failure in packet transfer may be e.g. a link failure between the CDF and CGFl, or a capacity 
exhausting error in the storage device of CGFl, or a general CGFl system failure or CGFl maintenance break.) 
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Figure 5.4: Duplicate prevention case: CDR sending via CGFl had not succeeded 

1) The CDR generating entity (CDF) sends CDR(s) in a packet to CGF (that is, the current primary CGF for the 
specific CDF, "CGFl "). The sending is performed by using the Data Record Transfer Request message, with the 
Packet Transfer Command IE having the value "Send Data Record Packet". 

2) Due to a failure in the CDF-CGF 1 communication link of CGFl, the CGFl is not able to store the packet sent 
by the CDF in a safe way (to e.g. a redundant RAM memory unit or a mirrored non-volatile memory or to 
another node). 

3) Therefore the CDF is not able to get a response (or it could alternatively get a negative response like "No 
resources available" as the Cause value in the Data Record Transfer Response message). 
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4) The CDF may now first test the CDF-CGF2 Hnk by an Echo Request message that the CGF2 would respond by 
the Echo Response.) Then, the CDF sends the same CDR packet that could not be sent to CGFl to the next 
CGF in its CGF preference list (here CGF2) using the Data Record Transfer Request message, with the Packet 
Transfer Command IE having the value "Send possible duplicated Data Record Packet". 

5) As the connection to the CGF2 is working, the CGF2 is able to process the CDR packet. Since the packet was 
marked by the sending CDF to be potentially duplicated, it is stored into the CGF2, but not yet sent forward 
towards the BD. 

6) The CGF2 sends confirmation of the successful packet reception to the CDF. The confirmation is performed by 
using the Data Record Transfer Response message, with the Cause value being "Request Accepted" 

7) The CDF can now delete the now successfully sent (potentially duplicated) CDRs from its CDR buffer (but it 
keeps the sequence number(s) of the sent potentially duplicated packet(s) in a buffer dedicated for that. 

8) When CGFl is recovering after a system reboot, it sends a Node Alive Request message to the configured peer 
CDF(s), and so the CDF notices that it can again successfully communicate with the CGFl. (The CDF may also 
detect this by using the Echo Request messages, which would be answered by CGFl by the Echo Response 
message.) 

9) CDF acknowledges the CGFl by Node Alive Response message. 

10) For the earlier unacknowledged Data Record Transfer Request message(s), the CDF sends CGFl empty test 
packet(s) (with no CDR payload in the Data Record Packet IE but just the other parts of the message frame). 

11) CGFl responds with Data Record Transfer Response message, with the Cause value being "Request 
Accepted", because in this example case CGFl had lost the communication capability towards CDF before 
storing the previously received (and by CGFl unacknowledged) CDR packet. 

12) Now CDF knows that the CGFl had not originally been able to process and forward the original version of the 
CDR packet from the CDF, and it indicates CGF2 that CGF2 can send the CDR packet(s) related to the 
previously unacknowledged GTP' Sequence Number(s) to post-processing. Those packets' Sequence Numbers 
are indicated in the Sequence Numbers of the Released Packets IE. 

13) CGF2 shall now be able to send the released records towards the post-processing system. 

14) CGF2 responds with Data Record Transfer Response message, with the Cause value being 'Request Accepted'. 

After all the potentially duplicated packets are cleared from CGF(s), the CDF can continue in normal way the transfer 
of CDRs. 
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5.2.2.3 



The CDF-CGF connection breaks after a successful CDR reception 
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Figure 5.5: Duplicate prevention case: CDR sending via CGFl had succeeded 

1) The CDR generating entity (CDF) sends CDR(s) in a packet to CGF (that is the current primary Charging 
Gateway Functionality for the specific CDF, "CGFl"). The sending is performed by using the Data Record 
Transfer Request message, with the Packet Transfer Command IE having the value "Send Data Record Packet". 

2) The CGFl is able to store the packet sent by the CDF in a safe way (to e.g. a redundant RAM memory unit or a 
mirrored non- volatile memory or to another network element, e.g. post-processing system). 
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3) Since the CDF-CGFl communication connection is now broken, the CDF is not able to get the response 
"Request Accepted" as the Cause value in the Data Record Transfer Response message. 

4) Then the CDF sends the same CDR packet that could not be sent to CGFl to the next CGF in its CGF preference 
list (here CGF2) a Data Record Transfer Request message, with the Packet Transfer Command IE having the 
value "Send possible duplicated Data Record Packet". (That sending may be preceded by the testing of the CDF- 
CGF2 link by an Echo Request message, that the CGF2 would respond by the Echo Response.) 

5) As the connection to CGF2 is working, CGF2 is able to process the CDR packet. Since the packet was marked 
by the sending CDF to be potentially dupUcated, it is stored in CGF2, but not yet sent forward towards the post 
processing or BD. 

6) The CGF2 sends confirmation of the successful packet reception to the CDF. The confirmation is performed by 
using the Data Record Transfer Response message, with the Cause value being "Request Accepted". 

7) The CDF can now delete the now successfully sent (potentially duplicated) CDRs from its CDR buffer (but it 
keeps the sequence number(s) of the sent potentially duplicated packet(s) in a buffer dedicated for that. 

8) When CGFl is recovering after a system reboot, it sends a Node Alive Request message to the configured peer 
CDF(s), and so the CDF notices that it can again successfully conomunicate with the CGFl. (The CDF may also 
detect this by using the Echo Request messages, which would be answered by CGFl by the Echo Response 

message.) 

9) CDF acknowledges the CGFl by Node Alive Response message. 

10) For the earlier unacknowledged Data Record Transfer Request message(s), the CDF sends CGFl empty test 
packet(s) (with no CDR payload in the Data Record Packet IE but just the other parts of the message frame). 

11) CGFl responds with Data Record Transfer Response message, with the Cause value being "Request related to 
possibly duplicated packets already fulfilled", because in this example case CGFl had lost the communication 
capability towards CDF after storing the previously received (and by CGFl unacknowledged) CDR packet. 

12) Now CDF knows that the CGFl had originally been able to process and forward the original version of the CDR 
packet from the CDF, and it indicates CGF2 that CGF2 can cancel the CDR packet(s) related to the previously 
unacknowledged GTP' CDF-CGFl Sequence Number(s). Those packets' Sequence Numbers are indicated in the 
Sequence Numbers of the Cancelled Packets IE. 

13) CGF2 shall now delete the cancelled packet(s) from its buffer for potentially duplicated packets. 

14) CGF2 responds with Data Record Transfer Response message, with the Cause value being "Request Accepted". 

After all the potentially duplicated packets are cleared form CGF(s), the CDF can continue in normal way the transfer 
of CDRs. 

5.2.2.4 CGF redundancy mechanism 

A summary of the CGF redundancy mechanism, which prevents duplicated CDR packets to enter the BS, 
is described below. 

This, or other mechanisms, are deployed to enhance the reliability of CDR transport. 

The general logic of the duplicate CDR packet prevention in CGF redundancy cases is shown in Figure 5.6, where the 

messages are numbered sequentially, alternative messages are indicated by an index character ("a" or "b") that follows 
the arrow sequence number. The main mechanism of the messaging in CGF redundancy cases (when a CDF-CGF link 
is down or a CGF is not working) is based on CDF (1) first trying to send a CDR packet to CGFl. In case no 
acknowledgement or a successful response is received (2) from CGFl due to any reason, e.g. such as the request not 
reaching CGFl despite repeated attempts (or the responses from CGFl to the CDF are lost after the CGFl has either 
stored it securely, or, forwarded it towards post-processing (2b)), the unacknowledged CDR packets are redirected to 
CGF2. The invocation for a re-transmission may be triggered by a time-out mechanism. 

The CDF may first test the CDF-CGF2 link by sending an 'Echo Request' message to CGF2, in response to which 
CGF2 would respond with the 'Echo Response' message. The CDR packets not successfully received by the primary 
CGF (=CGF1) are sent to CGF2 (3), and are marked as potential duplicates, and CGF2 responds to the request(s) (4). 
Such CDRs, i.e. CDRs that are marked as potential duplicates would wait there for further conomands from CDF. 
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When the CDF detects (5) & (6) that the primary CGF, in this case CGFl is again able to communicate with it on 
receiving Node Alive Request (or getting a Echo Response from CGF2 to a Echo Request sent by the CDF) it answers 
by Node Alive Response. Then the CDF tests CGFl with an empty packet (7), retrying continuously if no response is 
received, using e.g. increasing timeouts (using the old unacknowledged packet's Sequence Number, if the CGFl would 
consider the packet to be a new one (8a) or an already received one (8b)). According to the response received from 
CGFl, the CDF gives the CGF2 a command to either release (9a) or cancel (9b) the corresponding CDR packet from 
CGF2. CGF2 then confirms the decision (10), and is able to send the CDRs towards the BS (11a). 

Error handling: By default, retransmissions after configurable timeouts are used. If after the CGFl communication 
failure, the CDR packet sending from CDF to CGF2 does not succeed, the CDF tries to use CGF3 as the intermediate 
CDR packet storage entity, etc. If no acknowledgement (10) is received by the CDF for its message(s) (9a) or (9b), the 
CDF will retransmit the message (9a) or (9b) continuously and persistently, using e.g. increasing time intervals. An 
alarm should be sent to the O&M system if a communication Unk goes down. It shall be possible to release/cancel CDR 
packets from CGFs and unacknowledged sequence numbers from CDFs by O&M operations if permanent CDF-CGF 
link failures would occur. The buffers containing the Sequence Numbers of potentially duphcated packets, and the 
buffers containing the numbers of unacknowledged CDR packets shall be kept up to date (with CDR packet transfers) 
using transaction mechanisms. In the case of the CDF-CGFl communication link being down, any new CDRs 
generated by the CDF are sent to a properly working CGF2, instead of the CGFl. 
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Figure 5.6: General CGF redundancy messaging sclieme 
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A more detailed description of the CGF redundancy mechanism: 

Due to a network failure/network congestion or a temporary node failure, a CGF might not be able to send a response 
within the configured timeout period to a request it got from a CDF. As a first attempt, retries of requests are to be used 
as defined in TS 29.060 [200], if the response is not received in the configured time. 

If a CDF loses its connection to the CGF unexpectedly, it may send the CDRs to the next CGF in the priority hst. If the 
CGF changes, the CDF can continue sending CDRs to different CGF nodes, depending on which CGF has been 
configured as the receiver of CDRs for a particular service. 

Sequence number buffers: The CDF might lose its connection to its primary CGF due to a link failure or CGF going 
down. In this kind of redundancy condition the CDF attempts to redirect the CDR traffic to a secondary CGF (after 
possible retries have failed). The CDF maintains an internal buffer for Sequence Numbers of requests not yet 
successfully responded to by the primary CGF, for the case that it may become capable of communicating to the 
primary CGF at a later date. The CDF will send the not responded Data Record Packets (DRPs) to the secondary CGF, 
and the CDF maintains also a buffer for the Sequence Numbers related to those DRPs that have been temporarily stored 
to this secondary CGF. (If the communication towards the secondary CGF would not work, the transfer of possibly 
duphcated DRPs and Sequence Number bookkeeping would be done for a tertiary CGF etc.) Also the CGFs maintain 
Sequence Number buffers for each of their CDF links. The Sequence Numbers may in future be needed in relation to 
the possibly duphcated CDRs that the CGFs have got from the CDF(s). The Sequence Numbers are stored to wait for a 
final decision to release them towards the BS (if the primary CGF had not received successfully the packets originally 
sent by a CDF) or to cancel them (if the primary CGF had received and processed successfully the originally by CDF 
sent packets). 

The CDF is able to instruct CGF2 to cancel (or instruct CGF2 to transfer towards the BS), the CDR packets sent to a 
secondary CGF if the primary CGF becomes available for service. To make the right decision the CDF first sends an 
empty test packet with the 'Send possibly duplicated Data Record Packet' Packet Transfer Command to the primary 
CGF, using a previously not responded Sequence Number. 

In case that the empty test packet to the primary CGF (which was temporarily down (or to which the link was down)) is 
responded with the Cause value "Request Accepted", the CDF will release the corresponding CDRs waiting for final 
decision in the secondary CGF, towards the BD with the Packet Transfer Command "Release Data Record Packet". 

If the primary CGF responses this test message with the Cause value "Request related to possibly duplicated packets 
already fulfilled", the CDF will cancel the corresponding CDRs waiting for final decision in the secondary CGF, using 
the Packet Transfer Command "Cancel Data Record Packet". 

To enable that a CDF failure (destroying its Sequence Number buffers per each CGF link for non-responded requests or 
possibly duplicated packets) would not cause CDR packets to stay forever in the temporary decision waiting buffers of 
CGFs, there should also be O&M means of emptying those CGF buffers. 

There shall also be a configurable parameter in the CGF for making the final decision, as to whether or not it is able to 
send the CDRs to the BS for the case where the backup buffering mechanism in the CDF could not be used until the end 
of the messaging sequence related to a certain CDR packet has been completed. This way the operator can: 

A) Select that the CDFs and CGFs take care of duphcate prevention and the BS is not required to do duplicate 
checking due to possible duplicates caused by Network Element or CGF redimdancy mechanisms. 

B) Select that the BS performs the duplicate prevention. To do this in the most effective way, the CGF may include 
an additional flag linked to possibly duplicated CDRs sent to the BS, indicating that they have not been released 
by a CDF for BS use (or use special kind of file name if a file protocol is used between CGF and BS). This 
means that the BS has somewhat more processing work to do, but the BS would anyway get a duplicate free end 
result. CGF is in this case always authorised to forward CDRs towards the BS, also when they contain possibly 
duplicated data. For this case the CGFs may also have a configurable flag that Data Record Packet 
Cancel/Release operations are not needed. 
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6 Data description for the transfer 
6.1 The GTP' charging protocol 

This clause describes the features of GTP'. The message types described in subclause 6.2.2 ("Reused GTP message 
types") are also described in the related clauses of TS 29.060 [200]. 

6.1 .1 Usage of GTP Header in charging 

In GTP' messaging only the signalling plane of GTP is partly reused. The GTP' header is shown in Figure 6.1. 

Bit 5 of octet 1 of the GTP header is the Protocol Type (PT) flag: it is '0' if the message is GTP'. 
The Version bits indicate the GTP' protocol version when the Protocol Type flag is '0'. 

Bit 1 of octet 1 is not used in GTP' (except in vO), and it is marked '0' in the GTP' header. It is in use in GTP' vO and 
distinguishes the used header-length. In the case of GTP' vO, this bit being marked one (1) indicates the usage of the 6 
octets header. If the bit is set to '0' (usually the case) the 20-octet header is used. For all other versions of GTP', this bit 
is not used and is set to '0'. However, this does not suggest the use of the 20-octet header, rather a shorter 6-octet header. 

The Length indicates the length of payload (number of octets after the GTP' header). The Sequence Number of the 
packet is part of the GTP' header. 
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Figure 6.1: GTP' lieader 

6.1 .2 Information Elements (lEs) 

The messages may contain several Information Elements (lEs). The TLV (Type, Length, Value) or TV (Type, Value) 
encoding formats shall be used for the GTP' lEs. The GTP' messages shall have the lEs sorted with the Type fields in 
ascending order. The Length field shall contain the IE length excluding the Type and Length fields. 

Within the Type field the most significant bit will be set to when the TV format is used and set to 1 when the TLV 
format is used. This is illustrated in Figures 6.2 and b, respectively. 
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Figure 6.2: Type field for (a) TV and (b) TLV format 
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6.2 



GTP' Message Types 



6.2.1 



List of all GTP' message types 



GTP' defines a set of messages between two associated nodes. The GTP' messages defined are shown in Table 6.1. 
The messages introduced by GTP' are in boldface letters. The other messages are inherited from the GTP protocol. 

The GTP' introduced signalUng message types 

- Node Alive Request, 

- Node AUve Response, 

- Redirection Request and 

- Redirection Response 

belong to the "Path Management messages", while 

- Data Record Transfer Request and 

- Data Record Transfer Response 

are from the message type group "Record Transmission messages". 

The reserved fields in the signalling messages shall be filled with ones, and are intended for future use. 

GTP' reuses the GTP Cause values. The message type numbers required for the newly introduced GTP' messages have 
been derived from the unallocated message type number space specified in the GTP message table defined in TS 29.060 



The number ranges allocated for GTP' are as follows: 

For Information Elements: 117-127 (TV type fields) and 239-254 (for TLV type fields). 

TLV Information Element types introduced in the present document: 

254 Address of Recommended Node 

253 Requests Responded 

252 Data Record Packet 

25 1 Charging Gateway Address (this IE is also used in TS 29.060 [200]) 
250 Sequence Numbers of Cancelled Packets 

249 Sequence Numbers of Released Packets 

TV Information Element types introduced in the present document: 

127 Charging ID 

126 Packet Transfer Command 

For Cause Codes: Cause values used in requests: 49 to 63, Cause values used in responses indicating acceptance: 177 
to 191, Cause values used in responses indicating rejection: 241 to 255. 

Charging related Cause values introduced for the present document: 

In requests: 

63 This node is about to go down 

62 Another node is about to go down 
6 1 The receive buffers are becoming full 
60 The transmit buffers are becoming full 
59 System failure 

In responses indicating acceptance: 
177 CDR decoding error 

In responses indicating rejection: 

255 Request not fulfilled 

254 Sequence numbers of released/cancelled packets IE incorrect 

253 Request already fulfilled 

252 Request related to possibly duplicated packets already fulfilled 



[200]. 
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The charging related message types are Usted in Table 6. 1 . Brief descriptions of the GTP messages reused in GTP' are 
provided in subclause 6.2.2 ("Reused GTP message types") below. Further details are provided in TS 29.060 [200], the 
GTP specification. 
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Table 6.1: GTP' messages 

6.2.2 Reused GTP message types 

The existing Echo Request and Echo Response messages defined in TS 29.060 [200] are also used in PS domain 
charging. They may be used by the CDF or by the CGF for checking if another CDF or CGF is alive. If the present 
document and TS 29.060 [200] differ in their description, then the TS 29.060 [200] is to be taken as the latest 
specification status of the related Information Elements. If the path protocol is TCP, Echo Request and Echo Response 
messages are not required. 

The Version Not Supported message in the GTP' is similar to the corresponding GTP message. It indicates the latest 
GTP' version that the GTP' entity can support. If a receiving node receives a GTP' message of an unsupported version, 
then this node shall return a GTP' Version Not Supported message, indicating in the Version field of the GTP' header 
the latest GTP' version , this node supports. The received payload data of the GTP' packet shall then be discarded. 

The Version bits in the GTP' header have currently the following possible values: 

• GTP' version (binary '000') identifies the following Message Type values: 

3 = Version Not Supported, 

4 = Node Ahve Request, 

5 = Node Alive Response, 

6 = Redirection Request, 

7 = Redirection Response. 

In clause 7.3.4.6 the Requests Responded information element has Length field in place of the Number of Requests 
Responded field, to make that TLV IE to be handled Uke normal TLV lEs. 

If GTP' vO is used in parallel with GTP' v2 or a later version, then, a 6-octet header length (with no traiUng dummy 
octets) is used also with vO (like in GTP' v2). 

The mark of the usage of GTP' vO with 6 octet header (instead of the original 20 octet long header) is then the version 
bits being and the bit 1 of octet 1 being '1' (instead of '0'). 

GTP' version 1 (binary '001') is the same as version but has, in addendum, the duplicate CDR prevention 
mechanism, introduced in GSM 12.15 version 7.2.1 (1999-07) of the GPRS charging specification. 

- GTP' version 2 (binary '010') is the same as version 1, but the header is just 6 octets long (no unused traihng octets). 
IPv6 address type is also supported (for Address of Recommended Node information element of the Redirection 
Request). 
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6.2.3 GTP message type modifications, implied by GTP' 

The general principle is that the CDRs are always sent to a CGF residing in the same network as the CDF. In the case of 
roaming it is conceivable that some CDRs relating to the same service (e.g. in PS domain for the same PDP context) 
will be sent to different networks' CGFs. The cost balancing of the roaming traffic is to be agreed between the UMTS 
Operators. 

The PS domain charging related features in GTP are in the Create PDP Context Response: the Charging ID Information 
Element (IE) and the Charging Gateway Address IE, in the Update PDP Context Response the Charging ID Information 
Element (IE) and the Charging Gateway Address IE, in the Create AA PDP Context Response: the Charging ID IE and 
the Charging Gateway Address IE. Refer to TS 29.060 [200] for details. 

6.2.4 GTP' message types 

6.2.4.1 Node Alive Request 

The Node Alive Request message may be used to inform that a node in the network has started its service (e.g. after a 
service break due to software or hardware maintenance or data service interruption after an error condition). A node 
may send a different Node Address than its own in the Information Element, e.g. informing the "next node in the chain" 
that the "previous node in the chain" (which is located on the other side of the sender of this message) is now ready for 
service. This message type is optional if the Path Protocol is TCP. 

The Node Alive Request message allows a quicker reconnect capability than the Echo Request message based polling 
can provide, and its usage will have a reduced load effect on the network, particularly when the number of network 
nodes using GTP' is high. It may also be used to inform when a new network node has become available for service. If 
the Echo Request message is also used, then the usage of the Node Alive Request message allows the interval of Echo 
Requests to be longer, thus reducing network load by reducing number of Echo Requests. 
The Information elements in a Node Alive Request message are shown in Table 6.2. 



1 nf ormatillMlilllllill^lB 


■■Mi^rice requirement 


Node Address 


Mandatory 


Alternative Node Address 


Optional 


Private Extension 


Optional 



Table 6.2: Information Elements in a Node Alive Request 

The Node Address format is the same as for the Charging Gateway Address format described in TS 29.060 [200]). 

The format definition for the Node Address information element is the same as the format of the source and destination 
address of the IP packet that transports the GTP' messages. The optional Alternative Node Address IE can be used in the 
Node Alive Request if the message sender wants to advertise an IP address that is different from the node address 
format. This way both the IPv4 and IPv6 node address formats can be supported simultaneously in the messaging, 
regardless of whether IPv4 or IPv6 is used in the underlying transport. 

The optional Private Extension IE contains vendor- or operator-specific information. 

6.2.4.2 Node Alive Response 

The Node Alive Response message, shown in Table 6.3, shall be sent as a response to a received Node Alive Request. 



Information Element 


Presence requirement 


Private Extension 


Optional 



Table 6.3: Information Elements in a Node Alive Response 

The optional Private Extension IE contains vendor- or operator-specific information. 
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6.2.4.3 Redirection Request 

There are two use cases for the Redirection Request message: 

- One is to advise that received CDR traffic is to be redirected to another CGF 

due to the sending CGF node is about to stop service (due to an outage for maintenance or an error condition). 

- The second purpose is to inform a CDF which is currently sending data to this node (e.g. CGF), 

that the next node in the chain (e.g. a mediator device or Billing Computer) has lost connection to this node 
(e.g. CGF). 

The Information Elements in a Redirection Request Message are listed in Table 6.4. 

An Address of Recommended Node may be given if, for example, a CGF maintenance outage is handled by first 
introducing another CGF ready to take incoming CDRs. This way, the network performance can be maintained. The 
Address of Recommended Node shall only describe an intra-PLMN node containing a CGF, and not a node in any other 
PLMN. 



Information Element 


Presence requirement 


Cause 


Mandatory 


Address of Recommended Node 


Optional 


Alternative Address of Recommended Node 


Optional 


Private Extension 


Optional 



Table 6.4: Information Elements in a Redirection Request 



Possible Cause values are: 

"This node is about to go down" ; 
"Another node is about to go down"; 
- "System failure"; 

"Receive buffers becoming fiiU" ; 
"Send buffers becoming full". 

The Address of Recommended Node information element, shown in Figure 6.3, defines the IPv4 or IPv6 format address 
that the node is identified by in the UMTS network. 

Bits 

Octets 8 7 6 5 4 3 2 1 

Type = 254 (Decimal) 
Length = 4 (Decimal) 
IPv4 Address 



Bits 

Octets 8 7 6 5 4 3 2 1 

Type = 254 (Decimal) 
Lengtin = 1 6 (Decimal) 
IPv6 Address 



Figure 6.3: Address of Recommended Node information elements 

The format definition for the Address of Recommended Node information element is the same as the format of the 
source and destination address of the IP packet that transports the GTP' messages. The optional Alternative Address of 
Recommended Node IE can be used in the Node Alive Request if the message sender wants to advertise an IP address 
that is different from the node address format. This way both the IPv4 and IPv6 node address formats can be supported 
simultaneously in the messaging, regardless of whether IPv4 or IPv6 is used in the underlying transport. 

The optional Private Extension contains vendor- or operator- specific information. 
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6.2.4.4 Redirection Response 

A Redirection Response message shall be sent as a response of a received Redirection Request. 
The information elements of this message are listed in Table 6.5. 





^^^^nce requirement 


Cause 


Mandatory 


Private Extension 


Optional 



Table 6.5: Information Elements in a Redirection Response 

Possible Cause values are: 

- "Request Accepted"; 
"No resources available"; 
"Service not supported"; 

- "System failure"; 
"Mandatory IE incorrect"; 
"Mandatory IE missing"; 
"Optional IE incorrect"; 
"In vahd message format"; 
"Version not supported". 

The optional Private Extension contains vendor- or operator-specific information. 

6.2.4.5 Data Record Transfer Request 

This message is used to transmit the CDR(s) to the CGF. 

The CDRs are placed in the Data Record Packet information element. 

6.2.4.5.1 Information Elements in Data Record Transfer Request 

The Information Elements in Data Record Transfer Request message is specified in Table 6.6. 



Packet Transfer Command 


Mandatory 


Data Record Packet 


Conditional 


Sequence Numbers of Released Packets 


Conditional 


Sequence Numbers of Cancelled Packets 


Conditional 


Private Extension 


Optional 



Table 6.6: Information Elements in a Data Record Transfer Request 
6.2.4.5.2 Packet Transfer Command IE 

The value of the Packet Transfer Command in its Information Element tells the nature of the message: 

1 = 'Send Data Record Packet'; 

2 = 'Send possibly duplicated Data Record Packet'; 

3 = 'Cancel Data Record Packet'; 

4 = 'Release Data Record Packet'. 

The following describes the usage of each Packet Transfer Command. The first command is for normal CDR transfer 
while the other values are only used as part of the redundancy mechanism. 

1) Send Data Record Pacliet. This is the usual command used for sending CDRs under normal conditions when no 
error recovery is needed or the redirection mechanism is not involved. It is shown in Figure 6.5. The other three 
commands are being used only in error recovery cases. Out of the three conditional lEs shown in Table 6.6, only the 
"Data Record Packet" is present in this message. 
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2) Send possibly duplicated Data Record Packet. When the CDR packet is redirected to a secondary CGF (by a 
CDF) because the currently used CGF is not working or the CDR transfer is not working properly, or if there is an error 
in the link between the CDF and the CGF, then this Packet Transfer Command is used instead of the normal 'Send Data 
Record Packet'. Of the conditional lEs, the "Data Record Packet" is present in the message, when sending the message 
to a CGF acting as temporary storage, when the original primary CGF could not be contacted. This Packet Transfer 
Command is used also when sending "empty" test packets with older (but not yet acknowledged) sequence numbers 
after a peer node or link recovery, to check if the CGF had received some Data Record Packets (whose 
acknowledgement did not come to the Data Record Packet sending node) before the link to the recipient node became 
inoperable. 

3) Cancel Data Record Packet. Of the conditional lEs, the "Sequence Numbers of Cancelled Packets" is present in 
the message. 

4) Release Data Record Packet. Of the conditional lEs, the "Sequence Numbers of Released Packets" is present in the 

message. 



Bits 

Octets 8 7 6 5 4 3 2 1 

1 I Type = 126 (Decimal) 

Q Packet Transfer Command 



Figure 6.5: Packet Transfer Command information element 

After the CGF has received the Packet Transfer Command 'Release Data Record Packet' with the Sequence Number(s) 
for earlier sent 'Send possibly duplicated Data Record Packet' command(s), it can consider itself authorised to send the 
Data Record Packets previously marked as possibly duplicated towards the BD as normal (not duplicated) CDRs. 
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6.2.4.5.3 Data Record Packet IE 

The Data Record Packet element, which is present conditionally if the Packet Transfer Command is 
'Send Data Record Packet' or 'Send possibly duplicated Data Record Packet', may contain one or more CDRs. This IE 
is illustrated in Figure 6.6. If an "empty packet" is to be sent, then the Data Record Packet IE contains only the Type 
(with value 252 in decimal) and the Length (with value 0) fields. 

As shown in Figure 6.6, there are two fields identifying the CDR format: 
Data Record Format and Data Record Format Version. 

The format of the CDRs is ASN. 1 or some other format, as identified by the value of Data Record Format. 

The Data Record Format Version identifies the TS release and version numbers that were used for the CDR encoding. 

The formats of these two fields are described in detail in sections 6.3 and 6.4. 

Bits 

Octets 8 7 6 5 4 3 2 1 

Type = 252 (Decimal) 

Length 
Number of Data Records 



Data Record Format 



Data Record Format Version 



Length of Data Record 1 
Data Record 1 



X...X+1 

x+2...y 



Length of Data Record N 



Data Record N 



Figure 6.6: Data Record Packet information element 



6.2.4.5.4 



Sequence Numbers of Released Packets IE 



The Sequence Numbers of Released Packets is present if the Packet Transfer Command is 'Release Data Record 
Packet'. The format of the Information Element is described in Figure 6.7 below: 



Octets 
1 

2.. .3 
4...5 

n...n+1 



Bits 

5 



Type = 249 



Length 



Sequence Number 1 



Sequence Number N 



Figure 6.7: Sequence Numbers of Released Packets information element 
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6.2.4.5.5 



Sequence Numbers of Cancelled Packets IE 



The Sequence Numbers of Cancelled Packets information element is shown in Figure 6.8 and contains the IE Type, 
Length and the Sequence Numberis) (each 2 octets) of the cancelled Data Record Transfer Request{s). It is present if 
the Packet Transfer Command is "Cancel Data Record Packet". 



Octets 
1 

2.. .3 
4...5 

n...n+1 



Bits 

5 



Type = 250 



Length 



Sequence Number 1 



Sequence Number N 



Figure 6.8: Sequence Numbers of Cancelled Packets information element 



6.2.4.5.6 Private Extension IE 

The optional Private Extension contains vendor or operator specific information. 



6.2.4.6 Data Record Transfer Response 

The message shall be sent as a response of a received Data Record Transfer Request. 

Also, several Data Record Transfer Requests can be responded by a single Data Record Transfer Response. 



Information Element 


Presence requirement 


Cause 


Mandatory 


Requests Responded 


IVIandatory 


Private Extension 


Optional 



Table 6.7: Information Elements in a Data Record Transfer Response 

The Cause (whatever the value may be) appUes for all those Data Record Transfer Requests, responded by that 
particular Data Record Transfer Response. 

Possible Cause values are: 

"Request Accepted"; 
"No resources available"; 
"Service not supported"; 
"System failure"; 
"Mandatory IE incorrect"; 
"Mandatory IE missing"; 
"Optional IE incorrect"; 
"Invalid message format"; 
"Version not supported"; 

- "Request not fulfilled" ; 

- "CDR decoding error"; 
"Request already fulfilled"; 

"Request related to possibly duplicated packet already fulfilled" ; 
"Sequence numbers of released/cancelled packets IE incorrect" . 



The cause value "CDR decoding error" is optional, primarily intended to inform the CDF that the receiving node 
cannot decode the CDR. Thus, special features in the receiving node that are based on information within the CDR, 
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would not be operable. This message could alert the operator of a remote generating node of incompatible CDR 
encoding. It is optional and no action or response is required. 

The Requests Responded information element contains the IE Type, Length and the Sequence Numbers (each 2 octets) 
of the Data Record Transfer Requests. It is shown in Figure 6.9. 

Bits 

Octets 8 7 6 5 4 3 2 1 



Type = 253 
Length 
Sequence Number 1 



Sequence Number 2 



Figure 6.9: Requests Responded information element 

The optional Private Extension contains vendor or operator specific information. 

Depending on the Cause value severity and general occurrence frequency, the node that sent the corresponding Data 
Record Transfer Request, may start to direct its CDRs to another CGF. 



6.3 Data Record Format in GTP' 

The format of the PS domain CDRs, sent from CDF to CGF, is defined by the Data Record Format, which is the 5' 
octet of Data Record Packet information element, shown in Figure 6.6. 

The following rules govern the Data Record Format: 

• This field consists of one octet (#5). 

• The value range is 1-255 in decimal. The value '0' should not be used. 

• Only the values 1-10 and 51-255 can be used for standards purposes. 

• Values in the range of 1 1-50 are to be configured only by operators, and are not subject to standardization. 

• The value '1' identifies ASN.l Basic Encoding Rules (BER) encoding, 
which must be supported in PS domain charging. 

Other values for optional encodings are specified in subclause 6.3.1. 



6.3.1 Standard Data Record Format 

For the PS domain CDR transfer, defined by the present document, only an ASN. 1 BER encoding is mandatory. 
For this encoding, the Data Record Format value is 1'. 

Other ASN.l encodings may be supported optionally, with Data Record Format values as indicated below: 

• "1" signifies the use of Basic Encoding Rules (BER) 

• "2" signifies the use of unaligned basic Packed Encoding Rules (PER) 

• "3" signifies the use of aligned basic Packed Encoding Rules (PER) 



6.3.2 Private Data Record Formats 

The. Data Record Format vahies 11. ..50 (decimal) are reserved for private (implementation specific) format use. 
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6.4 Data Record Format Version for CDRs 

The CDR release and versions numbers are defined by the 'Data Record Format Version', in octet 6 and 7 of the Data 
Record Packet IE, shown in Figure 6.6. The format of this field is depicted in Figure 6.10. 

The first octet (#6 in Data Record Packet IE) is divided into two fields each with 4 bits : 

The first field (bits 8-5 of octet 6 , see figure 6.10) identifies the apphcation. For charging purposes, the Application 
Identifier has a value of 1' (decimal). 

Other possible appUcations of GTP' may use different numbers. 

The second field (bits 4-1 of octet 6, see figure 6.10) identifies the release. 

The Release Identifier indicates the TS release, used to encode the CDR, i.e. its value corresponds to the first digit of 
the version number of the document [51], as shown on the cover sheet. 

The second octet (#7 in Data Record Packet IE) identifies the version of the TS used to encode the CDR, 

i.e. its value corresponds to the second digit of the version number of the document [51] 

(as shown on the cover sheet), plus '1'. 

E.g. for version 3.4.0, the Version Identifier would be "5". 

In circumstances where the second digit is an alphabetical character, (e.g. 3.b.0), the corresponding ASCII value shall 
be taken, e.g. the Version Identifier would be "66" (ASCll(b)). 



Data Record Packet IE 

Bits 

Octets 8 7 6 5 4 3 2 1 



6 


Application Identifier 


Release Identifier 


7 


Version Identifier 



Figure 6.10: Tlie Format of tlie Data Record Format Version Fieid 
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